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IHPP.OVED IHT^CT. COKPRSSSTO N METHOD AND APPAR:>TTT.q 

BackcrouTi d of the invention 

The present invention relates to data 
processing and more specifically to methods and 
apparatuses for performing image compression. 



Without image compression, the transmission of 
images requires an unacceptable bandwidth in many 
applications. As a result, methods of compressing 
images have been the subject of numerous research 
publications. Image compression schemes convert an 
image consisting of a two-dimensional array of pixels 
into a sequence of bits which are to be transmitted 
over a communication link. Each pixel represents the 
intensity of the image at a particular location 
therein. The transmission link may be an ordinary 
20 telephone line. 

Consider an image comprising a gray-scale 
representation of a photograph at a resolution of 
1000x1000 lines. Each pixel typically consists of 8 
bits which are used to encode 256 possible intensity 
levels at the corresponding point on the photograph. 
Hence, without compression, transmission of the 
photograph requires that 8 million bits be sent over 
the communication link. A typical telephone line is 
30 capable of transmitting about 9600 bits per second; 

hence the picture transmission would require more than 
10 minutes. Transmission times of this magnitude are 
unacceptable. 



As a result, image compression systems are 
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needed to reduce the transaission time, it will also 
be apparent to those skilled in the art that image 
compression systems may also be advantageously employed 
in image storage systems to reduce the amount of memory 
5 needed to store one or more images. 

Image compression involves transforming the 
image to a fom which can be represented in fewer bits 
Without losing the essential features of the original 
image. The transformed image is then transmitted over 
the communication link in question and the inverse 
transformation applied at the receiver to recover the 
image or a reasonable facsimile thereof. 

The degree to which the recovered image differs 
from the original image is referred to as the 
distortion of the image. Distortion is normally 
measured as the root mean square of the pixel by pixel 
differences of the original and recovered images. As 
Will be discussed in more detail below, images with the 
same level of distortion may differ greatly in their 
subjective distortion, i.e., distortion as perceived by 
an observer. Hence, choosing compression algorithins 
based on such measures of distortion may lead to 
methods that achieve less than the optimum result as 
Viewed from the human perspective. 



The compression of an image typically requires 
t^o steps, in the first step, the image is transformed 
to a new representation in which the correlation 
between adjacent pixels is reduced. This 
transformation is usually completely reversible, that 
IS, no information is lost at this stage. The number 
Of bits Of data needed to represent the transformed 

image are at least as large as -chat needed to represent 
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the original image. The purpose of this transformation 
is to provide an image representation which is more 
ideally suited to known compression methods. 

5 In the second step, referred to as 

quantization, each pixel in the transformed image is 
replaced by a value which is represented in fewer bits, 
on average, than the original pixel value. In 
general, the original gray scale is replaced by a new 

10 scale which has coarser steps and hence can be 
represented in fewer bits. The new gray scale 
typically has levels in which the different 
steps are of different size. The new gray scale is 
calculated from the statistical distribution of the 

15 pixel values in the transformed image. 

The quantization process typically results in 
loss of information, since there will always be at 
least two different pixel levels in the original gray 
scale that will be assigned to the same level in the 
new gray scale. For example, a single level in the new 
gray scale might correspond to levels 200 through 210 
in the above mentioned 256-level gray scale. Hence, 
the ability to make distinctions based on differences 
25 in pixel intensity in this range will be lost, since, 
after quantization, all pixels in this range will have 
been assigned the same level in the new gray scale. 
This loss of information will be referred to as 
quantization errors. 



20 



30 



The quantized image resulting from the above 
two steps is often further coded for transmission over 
the communication link in question. This coding is 



35 



completely reversible. Its purpose is to provide a 
more compact representation of the quantized picture. 
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At the other end of the cononunication linX. the coded 
-age .s decoded, the quantization transf onnation is 
reversed and the inverse of the first transformation 
performed on the resulting i.age to provide a 
5 reconstructed image. 

diff.. f '"^'"'^ ^° """"^ reconstructed i»age 

denend ""^^^ ^" 1' 

10 on r °" ^^"^ transformation and 

10 on the manner in which it interacts with the 

quantization system, m the following discussion, the 
first transformation in question will be referred to as 
the .mage transformation, m general, the image 
^""^f°™«tion is equivalent to calculating the 

Z'TZ"^ °' ' '^^''^ °^ ^-ge in some 

set of expansion functions in a manner analogous to 

2tZT\T ""^'^^ °^ ^ one-dimensicnal 

function These coefficients are then quantized and 

transmitted. At the receiving end, the image is 

functions in question by the transmitted coefficients 
ana then summing the results. 

25 " * 5"««iz.tio„ error causes 

an error .n the reccnstructea imege win depend on th! 
«pansxo„ functions i„ ^estion. xt is useful to 
def.„e two Classes of functions, those with compact 
support and those with non-compact support. For the 
purposes Of this discussion, a function has compact 
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If the expansion functions have non-compact 
support, then a quantization error can effect a Ce^- 
large portion of the reconstructed image, .ach pL^i 
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Of the reconstructed l„age .ay be viewed as being 
calculated by suming contributions fro» a number of 
expansion functions :nultiplied by the transr^itted 
coeffacaents. The nun^er of such functions that 
5 contribute to the intensity of a given pi.el in the 
reconstructed i.age depends on the compactness of the 
function set. chosen. The less compact the expansion 
set, the larger the number of functions that can 
contribute to each noini- *.v 
Tn reconstructed image. 

10 Thus, the probability that a guantieation error will be 
present is greater, m addition, an error in a 
coefficient which multiplies a function in a non- 

compact expansion set will ^-f^^^^- ^ 

f wii waxx affect many more pixels 

Prior art image transformations utilize non- 
compact expansion function sets. Hence, quantization 
errors tend to affect the entire image. Zn addition. 

Observers of the reconstructed images. These errors 
produce artifacts such as stripes in the' image. To 
lessen the visual impact of such artifacts, prior art 
systems Often incorporate low-pass filters. However, 

HIT IT" """"^^ p^""- ^-^^i^- 

Thus, this method of eliminating the artifacts is less 
than Ideal. l„ addition, the low-pass filtering 

c3""-'''''""' computational capacity in the image 
compression apparatus. This additional capacity 
increases the cost of the apparatus in question. 



The image transformation circuitry is a 
significant cost factor in image compression 
apparatuses. The required computational expense 
Clearly depends on the image transf onnation selected 
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Hence, an image compression apparatus which utilizes an 
image transformation which requires less computation 
than prior art image transformation would be very 
advantageous. 

Accordingly, it is an object of the present 
invention to provide an improved image compression 
method and apparatus . 

It is a further object of the present invention 
to provide an image compression apparatus and method 
which utilizes an image transformation based on a set 
of expansion functions which have compact support. 

It is yet another object of the present 
invention to provide an image compression apparatus and 
method which requires less computational capacity than 
prior art image compression systems. 

These and other objects of the present 
invention will become apparent to those skilled in the 
art from the following detailed description of the 
present invention and the accompanying drawings. 

Summary of the Invention 

The present invention comprises an apparatus 
and method for compressing an image. The image 
comprises a two dimensional array of pixels organized 
30 as a plurality of rows and columns. The apparatus of 

the present invention comprises image transforming 
circuitry for transforming the image to form a 
plurality of component images. The component images 
35 represent different spatial frequency components of the 
image and comprises two dimensional arrays of pixels. 
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The present invention also includes quantization ' 
circuitry for assigning integer values to the pixels of 
the component images. The transformation used to 
generate the component images comprises circuitry for 
generating two vectors, y^ and y„, from a linear array, 
where i runs from 1 to M. 



y^i^)^ Z a(k)x(2m-N+k) 
k=0 



N-l 

yHW= 2 a(k) (-l)^+lx(2in+l-k) 
k=0 ' 



Here, the number of components in y^ and y^ vill- depend- 
on the values assigned to x{i) for i<0 and i>M. m the 
preferred embodiment of the present invention 
3f(i)=x(i+M). In this case, y^ and y^j will have M/2 
components and m runs from o to M/2-l. The a(k) 
25 satisfy the conditions 



30 



N-l 
i=0 



35 



and 



N-l 
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X a(i)a(i+k) = 0 for any integer k which is 

non-zero and even 

5 wherein a(k) =0 for k<0 or k>(N-l) and N is an even 
nuiuber greater than 2 and less than 30, and 
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N-1 

r a(i) = 2. 
i=0 



The present invention also includes circuitry 
for recovering an image from its component images. 
This circuitry synthesizes a third image from first and 
second component images. The synthesizing circuitry 
includes circuitry for generating a vector z having 
components, z(i), from two arrays of pixels x^{i) and 
x^a), being taken from first component image and Xjj 
being taken from said second component image. Here, 



(N/2)-l (N/2)-l 
' v^n^^^^^''L^'""^''^*'/2)] + 2 a(2k+l)x„(m+k) 



(N/2)-l (N/2)-l 
2(2m+l)= r a(2k+l)xLtm+(N/2)-k) - T a(2k)XH(m+k) 
K=0 k=0 " 



wo 91/03902 



PCT/US90/04807 



10 



15 



20 



25 



30 



35 



Brief De5^rT-in tioTi of the DTZVir^g ^ 

Figure l is a block diagram of an image 
compression and decompression apparatus according .to 
the present invention. 

Figure 2 is a block diagram of an analyzer 
apparatus for decomposing an image into four component 
images . 

Figure 3 is a block diagram of a synthesizer 
apparatus for synthesizing an image from four component 
images of the type produced by the analyzer apparatus 
shown in Figure 2. 

Figure 4 illustrates the manner in which an 
image may be successively decomposed into a series of 
component images having different spatial frequencies. 



Detailed Descr-i n^--; on of i-h» invent-! 



on 



For the purposes of this discussion, an image 
wall be denoted by a two-dimensional MxM array of pixels 
^i.j- Although the present discussion will be limited 
to square arrays, the extension of the method to MxM' 
arrays, where M' is different from M, will be apparent 
to those skilled in the art. For the purposes of this 
discussion, it will be assumed that 1^ . is zero if 
either i or j is less than 0 or greater than M-l. 

Figure 1 illustrates an image compression 
system lo according to the present invention and the 
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related image decompression system 21. An image li is 
input to an image transformer 12 which transforms 
image 11 into a hierarchial image representation 14. 
Image representation 14 is then quantized by image 
quantizer 16. The quantized image version of image 
representation 14 is then encoded by image coder 18 
prior to being transmitted on communication link 20. 

The compressed image is received by image 
decompression system 21 where the above described 
process is reversed. The encoded transformed image is 
first decoded by image decoder 22 which recovers the 
quantized version of image representation 14. The 
levels in the quantized version of image representation 
14 are then replaced by the corresponding levels to 
form an approximation of image representation 14 which 
is shown at 26. The inverse of the image 
transformation performed by image transformer 12 is 
then applied to approximation 2 6 by inverse image 
transformer 28 which outputs the reconstructed image 
30. 

The image quantization and dequantization steps 
described above are conventional in the art; however, 
some discussion thereof will be useful in understanding 
the advantages of the present invention. In the 
preferred embodiment of the present invention, so 
called scalar quantization is utilized. Assume that, 
the pixels, li^jr in the original image had values 
distributed between 0 and 255, and that there were 
1,000,000 such pixels. Since an intensity value in 
this range can be represented by 8-bits/pixel , a total 
of 8x10^ bits are needed to represent the uncompressed 
image. 



35 
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The simplest method of compressing the image 
would be to reduce the number of allowable values for 
li j. For example, the number of bits could be reduced 
by a factor of two if only 4 bits were allocated for 
each pixel. However, in this case there would only be 
16 possible gray levels instead of the original 256. 
The gray level of a pixel in the quantized image would 
be the same as the corresponding pixel in the original 
image divided by 16. However, since only the integer 
part of the division is Jcept, all original values 
between 0 and 15 would now be represented by o, those 
between 16 and 31 would be represented by 1, and so on. 
The original image had a precision of 1 part in 256; 
hence, the compression has increased the error rate by 
15 a factor of 16 for a gain of only a factor of two in 
compression. 

Now assume that the above exemplary image can 
be transformed into two component images of different 

20 numbers of pixels. It will be assumed further that the 
inverse image transformation exists, i.e., the two 
component images can be recombined to forro the original 
image. The number of pixels in the first component 
image will be denote by s, and the number of pixels in 

25 second component image will be denoted by B. Assume 
further that S«B and that the spread of intensity 
values in S ia much greater than the spread in the 
intensity values of B. 



30 
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For example, the pixel values in S might be 
distributed between 0 and 255, while those in fi are 
di.^tributed between 0 and 7. The first component image 
will require Sx8 bits to represent. However, the 

second component image may be quantized allowing only 3 
bits per pixel; hence, it requires only Bx3 bits. Thus 



PCr/US90/04807 



-12- 



the two component images may be represented in Sx8 + 
Bx3 bits. As noted above, the transformation is 
assumed to have the property that S«B. Hence, the 
quantized component image representation requires only 
5 slightly more than 3 bits per pixel. That is, a 

compression ratio of between 2 and 3 ha been obtained. 
Furthermore, no loss in precision has occurred in this 
example, since the second component image only had 8 
different pixel values. That is, the reconstructed 
10 image obtained by applying the reverse transformation 
on the quantized image would be identical to the 
original image. 

If one is willing to introduce some errors into 
15 the compressed image, the compression ratio obtained in 
the above example may be increased. Suppose it were 
known that the information content of the second 
component image is less than that of the first image 
component. Then the accuracy with which the second 
0 image component need be represented is substantially 
less. In this case, the second component image .could 
be quantized with fewer bits. For example, one might 
use only 2 bits per pixel. In this case, the 
reconstructed image would differ from the original 
5 image. 



The degree to which the reconstructed image is 
distorted can be measured in both quantitative and 
subjective terms. In quantitative terms, the root 
mean square error between the pixels of the original and 
reconstructed images is often used to measure 
distortion. However, it must be noted that two images 

reconstructed from the same image and having the same 
root mean square error may appear significantly 
different depending on the manner in which the errors 
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are introduced. If, for example, the errors are all 
localized in one band of the reconstructed ir,age, the 
reconstructed image will appear to have a stripe. Such 
a striped image is subjectively more objectionable than 
an image which has random noise with an equivalent 
aggregate error added thereto. 

The manner in which the quantization errors are 
reflected in the reconstructed image will, in general, 
depend on the particular transformation used to convert 
the original into the component images. For example, 
when Fourier transforms or their equivalent are 
utilized, the above mentioned striping of the image 
often occurs. The effect of these artifacts can be 
reduced by post-processing the image through a low-pass 
filter. However, this solution increases the 
computational effort and lowers the resolution of the 
final reconstructed image. 

The above discussion of quantization utilized a 
particularly simple form of assigning the quantized 
levels to the individual levels in the images. More 
optimum methods are known to the art. in general 
these methods model the statistical distribution of the 
pixels in the image to be quantized. Given the 
distribution and its variance and the number of bits to 
be allocated to each pixel, one can calculate the 
optimum placement of the levels, since such 
optimization calculations are well Xnown in the art 
they will not be discussed in detail here. For more 
oetails Of the procedures in question, the reader is 

referred to William K. Pratt, Digital Image Processing, 
PP141-46, John Wiley s. Sons, Inc., New York, 1978, 
which is hereby incorporated by reference. 
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The coding and decoding steps described above 
are likewise known to the prior art and, hence, will 
not be described in detail here. These steps provide 
further compression of the quantized image. by 
5 exploiting various redundancies or repeated sequences 
in the data. A typical encoding and decoding system is 
described in the IBM Journal of Research and 
Development 32 No. 6 in a series of articles on the Q- 
coder. These articles are hereby incorporated by 
10 reference. It should- be noted that although such 

coding is preferred, image compression/decompression 
without it is also possible. 

In the above discussion, it was assumed that 
15 there existed a transformation that divided the image 
into component images of different sizes in which more 
of the information content of the image was 
concentrated in one of the component images than in the 
other component images, it was also noted that it 
>0 would be advantageous if the quantization error in 
one of the pixels of the transformed image at most 
affected a few pixels in reconstructed image. This 
latter condition guarantees that the errors are in the 
form of noise rather than stripes or other large are 
5 artifacts. The present invention provides such a 
transformation. 



The image transformation utilized in the 
present invention is an iterative process in which the 
original image is transformed into a series of 

component images. The information content of the 
various component images differ in a manner which 
allows the quantization step described above to provide 
a greater degree of compression for a given subjective 
image quality than would be obtained if one of the 
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image compression transformations utilized in prior art 
image compression systems had been utilized. 

The iteration process starts with the image to 
be compressed. In the preferred embodiment of the 
present invention, each step in the iteration transforms 
an MxM image into four (M/2)x(M/2) component images. 
Three of these component images contain information 
pertaining to the high spatial frequency components of 
the MXM image, the fourth is related to the low spatial 
frequency components. 

The elements of the component images obtained 
in the first iteration are coefficients of an expansion 
of the original image in a set of wavelet functions 
having compact support. The elements of the component 
images from the remaining iterations are coefficients 
Of an expansion of one of the component images obtained 
in the prior iteration. For simplicity, the elements 
of the various component images will be referred to as 
pixels in the following discussion even though they are 
not actually pixels in an optical image. ' 

The transformation is carried out in two steps 
as indicated in Figure 2. in the first step, an image 
42 consisting of M columns and M rows is transformed 
into two images denoted by L and H by a transformation 
circuit 44 which will be referred to as Analyzer 44. 
The L and H images each have (M/2) columns and M rows. 



Analyzer 44 operates on each row of image 42 as 
follows. Each row of image 42 may be viewed as 
consisting of a vector having M components, x(i). if M 
35 is not even, a zero is appended to x to force M to be 
even. Analyzer 44 multiplies the elements of x with 
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the elements of a vector having conponents a{k), where 
k runs from 0 to N-l, to form two vectors having 
components, y^^Ci) and 7^(1)- The vectors and y^^ 
are shown schematically at 4 6 and 48, respectively. 
5 These vectors each have M/2 such -elements. The 
components of y^Ci) and y^(i) are calculated as 
follows: 



10 

N-l 

yj^(m)= r a(k)x(2m-N+}c) 

^5 (1) 
N-l 

yjj(m)= z a(k) (-1) ^"^'^x (2m+l-k) 
k=0 

Here, m runs from 0 to (M/2)-l. The vector y^ obtained 
by so transforming the ith row of image 42 becomes the 
ith row of image L as shown in Figure 1. Similarly/ 
25 the vector obtained from the ith row becomes the. ith 
row of image H. 



The above described transformation requires 
that some value be assigned to pixels that lie outside 
3 0 the original image, i.e., x(i) for i<0 or i>M-l. In 

the preferred embodiment of the present invention, x is 
assumed to be cyclic, i.e., x(i)=x(i+M) . In this case, 
it can be shown that y^^ and yj^ are each periodic 
35 and have period M/2. 
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m prior art image compression systems, the 
image is often assumed to be embedded in a "sea of 
zeros". This is equivalent to defining x to be zlro 
for i<o or i>M-l. in this case, it can be shown that 
Vl yjj each have (M/2) + (n/2) elements. All of 
these elements must be retained if the image is to be 
accurately reconstructed. Hence, the memory required 
to store the component images is greater than that 
required to store zhe original image. Further, the 
exact size depends on the number of iterations 
performed. This complicates the design of the system 
components . 

In the second step in the transformation, each 
of the L and H images is further transformed into two 
(M/2 )x {M/2) component images. image L is used to 
create two images, LL and LH in a manner analogous to 
that described above, except that the image is divided 
into columns instead of rows. Each column is divided 
into Its M element column vectors. Each vector is 
transformed using Analyzer 44 into a two M/2 element 
column vectors having elements y^^ and y^ using the 
transformation defined in Zq. (i) . The vector y. 
Obtained by transforming the ith column of image L 
25 becomes the ith column of image LL. Similarly, the 
vector yjj becomes the ith column of image LH. The 
remaining images HL and HH are obtained in an analogous 
manner. 
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Provided the elements a{k) satisfy certain 
conditions which will be described in more detail 
below, the LL image can be shown to represent the low 
spatial frequency component of the data in image 42. 
Likewise, the remaining images can be shown to 
represent the high frequency components of the image. 
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The decomposition described above can be 
reversed to regenerate the original image 42 provided 
the a(k) satisfy the constraints described below. 
5 Figure 3 is a block diagram' of an apparatus for 

carrying out the reverse transformation. The apparatus 
combines the HH and HL components to generate an H 
image, and the LH and LL components to form an L image. 
Synthesizer 64 combines one column from HH and the 

10 corresponding column from HL to form a corresponding 
column of the H image. Similarly synthesizer €5 
combines two columns of the LL and LH to form a column 
of the L image. The L and H images are similarly 
combined by synthesizer 66 for form a reconstructed 

15 image 62. 

Synthesizers 64-66 operate on two vectors 
having components Xj^{i) and Xjj(i) to produce an output 
vector having components z(i). Synthesizers 64-66 are 
20 identical circuits, they are given different reference 
nimbers to facilitate the following discussion. The 
number of components in the output vector is twice that 
in each of the input vectors. The output vector is 
calculated as follows: 

25 



20 (N/2)-l (N/2)-l 

z(2m)= r a(2k)XL[m-k+(N/2) ] + Z a (2k+l) Xj^ (m+k) 

k* 0 ^ — ^ 



35 



k=0 



W2)-l (N/2)-l 
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2(2in-rl)= r a(2k+l)XL[in+(N/2)-k) - L a (2k) x„ (m+k) 
k=0 k=0 ' 

As noted above, the a(k) must satisfy certain 
conditions. These conditions will now be discussed. 
The first set of conditions are needed to guarantee 
that the image transformation by which a single vector 
X is split into components, and Xjj is invertable. 
That is, if a vector x is inputted to an analyzer which 
outputs vectors, x^ and Xj^, then the output of a 
synthesizer which has as its inputs Xj^ and Xj^ will be 
X. These conditions can be written as follows: 



N-1 ^ 

2 a^{x) = 1 
i=0 



and 



N-1 

Z a(i)a(i+k) = o .(4) 
25 i=o 

Here, a(k) = 0 for k<0 or k>(N-l), and k is any non- 
zero even integer. N must be an even number, 

30 



Although the conditions specified in Eqs (3) 
and (4) guarantee invertibility , they do not guarantee 
that Xj^ and will be the low and high frequency 
35 components of x. For this to be true, the a(k) must 
also satisfy the condition: 
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N-1 

. .2 a(i) = 2 

^ a=o (5) 

There a large nmnber of sets of a(i) that 
satisfy the above conditions. In the preferred 
10 en±)odi2nent of the present invention, the parameters 
a(k) further satisfy the condition; 

.lh8 

N-1 

" 2 a(N-l-i) (-l)iiQ = 0 (5 J 

i=0 



20 



25 



30 



where Q is any non-negative integer which less than or 
equal to (N/2)"l. The improvement obtained with this 
definition is related to the fact that the expansion 
coefficients are zero if x is a polynomial of degree 
less than N/2. 

In general it is desirable to use an N>4 , if 
N=2, the polynomial in question is a constant. If N=4 , 
the polynomial is a line. since a constant or linear ' 
approximation are poor approximations for any curve 
having finite curvature, such an approximations are 
likely to be a poor fit to the image data. In the 
preferred embodiment of the present invention, N=6, and 
t:he a(k) to an accuracy of four decimal places are as 
follows: 



35 



a(k) 
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0 .3327 

1 .8069 

2 .4599 

3 -.1350 

4 -.0854 

5 .0352 

As N is increased, the distortion introduced 
into the reconstructed image is reduced as measured by 
root mean square error. However, it is found 
experimentally that the subjective quality of the image 
begins to deteriorate if N is larger than 20 to 30. 
This latter observation results from the fact that the 
number of pixels in the reconstructed image that will 
15 be affected by a quantization error in one of the 
component errors is related to N. Hence, as N is 
increased, quantization errors can result in large 
artifacts such as blotches. 

^° Having described how an image nay be 

transformed into four images having differing 
spatial frequency components and the process reversed, 
the image transformation utilized in the compression 
system of the present invention will be described in 

25 more detail.' Referring to Figure 4, it will be assumed 
that the original image 72 has PxP pixels. image 72 is 
decomposed into four component images, 74-77, as 
described above, component image 74 being the LL 
image. Each of the component images 74-77 are 
30 (P/2)x(P/2) pixels. 



Next, component image 74 is decomposed into its 
four component images 80-83, component image 80 being 
35 the LL component image. Component images 80-83 each 
have (P/4)x(P/4) pixels. It should be noted that the 
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menory space needed to store the image at each stage of 
the decomposition is the same as that needed to store 
the original image. 

The iteration continues by decomposing the LL 
component into its component images at each stage. 
Hence, at the next stage, component image 80 will be 
decomposed into component images 84-87. The iteration 
may be continued until the LL component image is a 1x1 
image, i.e., a single pixel. However, in the preferred 
embodiment of the present invention, the process is 
terminated at the step just before the LL component 
image becomes less than NxN. 

Once the image has been transformed into the 
above described component image representation, each of 
the component images is quantized. As noted above, it 
is at the quantization step that information is lost. 

^° It is found experimentally that the information 

content of the lower frequency component images is 
higher, in general, than that of the higher frequency 
component images. That is, the observed variance of 
the statistical distribution of the pixels in the lower 

25 frequency component images is higher than the variance 
of the higher frequency component images. Hence, the 
transformation of the present invention can be used to 
provide good image compression by assigning more bits 
at the quantization stage to the lower frequency 

30- component images. 

In the preferred embodiment of the present 
invention, the statistical distribution of the pixel 
intensities in each of the component images is fit 
35 to a Laplacian distribution. The number of pixels 

assigned to each of the component images is then made 
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in relation to the veriance of the observed 
distributions and the desired level of image 
compression. it is found experimentally that 
satisfactory images may be reconstructed even after 
5 compressions in excess of 100:1. 

As noted above, some assumption must be made 
for the pixels values that lie outside the original 
image. The assumption that these values are 0 or that 
0 the image is periodic (i.e., x(i)=x(i+M)) results 

m the original image being viewed as consisting of a 
larger picture having an image with a discontinuity at 
the boundary of the original image. This type of 
discontinuity often results in artifacts in the images 
= produced by reconstructing a transformed image that 

has also been compressed.^ By terminating the iteration 
when the LL image is NxN, these artifacts are reduced. 

It should be noted that these edge artifacts 
' are less critical in the present invention than in 
prior art image compression systems. The image 
transformation utilized in the present invention is 
based on a digital wavelet transformation in which the 
wavelets have compact support, i.e.. the wavelets are 
only non-zero on" a small interval. This is reflected 
m the choice of N. As noted above, N is preferably 
snail, i.e., 6. so long as N is small compared to the 
number of pixels in the component image being 
decomposed, any such artifacts will be limited to a 
region near the boundary of the image. The size of 
this region will depend on the choice of N. 

It should be noted that prior art image 
compression schemes based on functional decompositions 
which satisfy conditions (1) through (6) above are 
known in the image compression arts. However, the 
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values of N utilized in these transformations are 
large, in these prior art schemes, Nis typically 
larger than 32. These methods use large N values 
because they are attempting to duplicate the results 
5 that would be obtained by a Fourier transformation based 
sub-band decomposition of the image. 

Because these methods use large values of N, 
they suffer from the various problems ' described above. 
10 They are computationally less efficient than the 

present invention. In addition, they suffer from non- 
local artifacts resulting from quantization errors. 

It may be shown that the calculations detailed 
15 in Eg. (1) above are equivalent to expanding the 

function whose digital representation is x(i) in a set 
of wavelet functions having compact support. The value 
of N is a measure of the support of the wavelets 
in question. N is related to the maximum number of 
2 0 grid points on which the wavlet functions have non-zero 
values. In general, a scaling function which is used 
to define a wavelet is defined as any function 
satisfying the recursion relationship 

25 



o{x)= r dy, 0(2x-k) (7) 
30 ^ = 2 (8) 



(9) 
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Here, k runs from 0 to N-1 and dj.=0 for k<0 or X>N-l. 
A wavelet, w(x), is any translation and/or dialation of 
scaling function, i.e., for j and k integers, 

w(x)= 2^/2 o(2^X-k) (^oj 

Although the above discussion has utilized gray 
scale images, it will be apparent to those skilled in 
the art that images having color may also be compressed 
utilizing the present invention. An image having color 
consists of a two-dimensional array of pixels in which 
each pixel is a vector having one component for each of 
the three primary colors. such an image can be thought 
of as three gray scale images. 

There has been described herein a novel image 
compression method and apparatus. Various 
modifications to the present invention will become 
apparent to those skilled in the art from the foregoing 
description and accompanying drawings. Accordingly, 
the present invention is to be limited splely by the 
scope of the following claims. 
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V7HAT IS CLAIMED IS: 



1. An apparatus for compressing an image 
comprising a two dimensional array of pixels organized 
5 as a plurality of rows and columns, said apparatus 

comprising: means for transforming said image to form a 
plurality of component images, said component images 
representing different spatial frequency components of 
said image and comprising two dimensional arrays of 

10 pixels; and quantizer means for assigning integer 

values to the pixels of said component images, wherein 
said transforming means comprises means for generating 
two vectors, y^^ and yj^, from a linear array, x(i) , of M 
pixels, and wherein y^ and y^^ have components defined 

15 by 

N-1 

yL(m)= z a(k)x(2m-N+)c) 
k=0 

20 

N-1 

yj^(m)- z a(k) ("l)^"^^x(2m+l-k) 
k=0 



and wherein the a(k) satisfy the conditions 

3 0 N-1 

Z a2{i) = 1 
i=0 

and 

35 



N-1 
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r a(i)a(i+}:) = o for k equal to any non-zero 

even integer 

wherein a(k) = 0 for k<0 or k>(N-l) and N is an even 
number greater than 4 and less than 30, and 
N-i 
2 a(i) = 2. 

10 i=o 



15 



20 



2. The apparatus of Claim 1 wherein the 
largest component image is no larger than NxN pixels. 

3. The apparatus of Claim i wherein said 
quantizer means comprises means for approximating the 
statistical distribution of pixel levels in each said 
component image by Laplacian probability distribution. 

4. The apparratus of Claim 1 wherein x(i) is 
defined to be x(i+M) and wherein m runs from 0 to 
(M/2)-l. 

5. An apparatus for decompressing an image 
which has been decomposed into a plurality of co»ponent 
images, said apparatus comprising synthesizing meani 
for combining first and second said component images to 
form a third image, said synthesizing means comprising 
rieans for generating a vector z having components, 
z(i), from two arrays of pixels x^(x) and x^Ci) , x, 
being taken from first component image and Xj, being 
taken from said second component image, wherein 



30 
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(N/2)-l • (N/2)"l 

2(2in)= Z a(2k)XL[in-k+(N/2)] + Z a (2k+l) x„ (m+k) 
k-0 k=o " 



(N/2)-l (N/2)-l 
2(2^1+1)= X a(2k+l)xLtm+(N/2)-k) - z a (2k) x„ (m+k) 
k=0 )c=o 



6. A method for compressing an image 
comprising a two dimensional array of pixels organized 
15 as a plurality of rows and columns, said method 

comprising the steps of: transforming said image to 
form a plurality of component images, said component 
images representing different spatial frequency 
components of said image and comprising two dimensional 
arrays of pixels; and assigning integer values to the 
pixels of said component images, wherein said 
transforming step comprises generating two vectors, yj^ 
and yjj, from a linear array, x(i), of M pixels, and 
wherein y^ and have components defined by 
N-1 

yL(3n)= Z a(k)x(2m-N-t-k) 
k=o 



yH(in)= Z a(k) (-l)^"^^x(2m+l"k) 
k=0 

and wherein the a(k) satisfy the conditions 
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N-1 

Z a^{i) = 1 
i=o 



and 



N-1 

10 iio ^ -ny even, non-zero 

integer 

Wherein a(Jc) = o for k<0 or k>(N-l) and N is an even 
number greater than 2 and less than 20, and 
N-1 

2 a(i) = 2. 
i=0 

20 

7. The method of Claim 6 wherein the largest 
component image is no larger than NxN pixels. 

8. The method of claim 6 wherein said step of 
25 assigning integers comprises for approximating the 

statistical distribution of pixel levels in each said 
component image by the Laplacian probability 
distribution. 

^° ^- method of Claim 6 wherein x(i) is 

defined to be x(i+M) and wherein m runs from 0 to 
(M/2)-l. 



35 



10. A method for decompressing an image, said 
image including first and second component images, each 
said component image comprising a plurality of pixels 



/ 
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organized as a plurality of rows or columns, said 

method comprising the step of combining said first and 

second said component images to form a third image, 

said combining step comprising generating a vector z 

5 having components, 2(i), from two arrays of pixels 

Xj^(i) and x^(i) , being taken from first component 

image and Xj^ being taken from said second component 

image, wherein 

0 (N/2)-l (N/2)-l 

2{2in)= 2 a(2k)Xr [m-k+(N/2) ] + Z a (2k+l) x„ (m+k) 
k=0 k=0 " 



i5 (N/2)-l (N/2)-l 

2(2m+l)= 2 a(2k+l)xT [m+{N/2)-k) - S a(2k)x„(m+k) 
k«=0 k=0 



20 



11. An apparatus for compressing an image 
comprising a two dimensional array of pixels organized 
as a plurality of rows and columns, said apparatus 
comprising: means for transforming said image to form a 
plurality of component images, said component images 
representing different spatial frequency components of 
said image and comprising two dimensional arrays of 
pixels, said transforming means comprising means for 
representing a linear array of M pixels in said image 
by a wavelet expansion in wavelets having support N, 
where 4<N<30; and quantizer means for assigning integer 
values to the pixels of said component images. 
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